[[...path]].page.tsx 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. import {
  2. NextPage, GetServerSideProps, GetServerSidePropsContext,
  3. } from 'next';
  4. import { useTranslation } from 'next-i18next';
  5. import dynamic from 'next/dynamic';
  6. import { useRouter } from 'next/router';
  7. import UserGroupPage from '~/components/Admin/UserGroup/UserGroupPage';
  8. import UserManagement from '~/components/Admin/UserManagement';
  9. import AdminLayout from '~/components/AdminLayout';
  10. import { CrowiRequest } from '~/interfaces/crowi-request';
  11. import { CommonProps, getServerSideCommonProps, useCustomTitle } from '~/pages/commons';
  12. import PluginUtils from '~/server/plugins/plugin-utils';
  13. import ConfigLoader from '~/server/service/config-loader';
  14. // import AdminHome from '~/components/Admin/AdminHome/AdminHome';
  15. // import AppSettingsPageContents from '~/components/Admin/App/AppSettingsPageContents';
  16. // import SecurityManagementContents from '~/components/Admin/Security/SecurityManagementContents';
  17. // import MarkDownSettingContents from '~/components/Admin/MarkdownSetting/MarkDownSettingContents';
  18. // import DataImportPageContents from '~/components/Admin/ImportData/ImportDataPageContents';
  19. // import ExportArchiveDataPage from '~/components/Admin/ExportArchiveDataPage';
  20. // import ElasticsearchManagement from '~/components/Admin/ElasticsearchManagement/ElasticsearchManagement';
  21. import {
  22. useCurrentUser,
  23. /* useSearchServiceConfigured, useSearchServiceReachable, */ useSiteUrl,
  24. } from '~/stores/context';
  25. // import { useEnvVars } from '~/stores/admin-context';
  26. const pluginUtils = new PluginUtils();
  27. type Props = CommonProps & {
  28. currentUser: any,
  29. nodeVersion: string,
  30. npmVersion: string,
  31. yarnVersion: string,
  32. installedPlugins: any,
  33. envVars: any,
  34. isSearchServiceConfigured: boolean,
  35. isSearchServiceReachable: boolean,
  36. siteUrl: string,
  37. };
  38. const AdminMarkdownSettingsPage: NextPage<Props> = (props: Props) => {
  39. const { t } = useTranslation();
  40. const router = useRouter();
  41. const path = router.query.path || 'home';
  42. const name = Array.isArray(path) ? path[0] : path;
  43. // const CustomizeSettingContents = dynamic(() => import('../../components/Admin/Customize/Customize'), { ssr: false });
  44. const adminPagesMap = {
  45. home: {
  46. title: useCustomTitle(props, t('Wiki Management Home Page')),
  47. // component: <AdminHome
  48. // nodeVersion={props.nodeVersion}
  49. // npmVersion={props.npmVersion}
  50. // yarnVersion={props.yarnVersion}
  51. // installedPlugins={props.installedPlugins}
  52. // />,
  53. component: <>AdminHome</>,
  54. },
  55. app: {
  56. title: useCustomTitle(props, t('App Settings')),
  57. // component: <AppSettingsPageContents />,
  58. component: <>AppSettingsPageContents</>,
  59. },
  60. security: {
  61. title: useCustomTitle(props, t('security_settings')),
  62. // component: <SecurityManagementContents />,
  63. component: <>SecurityManagementContents</>,
  64. },
  65. markdown: {
  66. title: useCustomTitle(props, t('Markdown Settings')),
  67. // component: <MarkDownSettingContents />,
  68. component: <>MarkDownSettingContents</>,
  69. },
  70. customize: {
  71. title: useCustomTitle(props, t('Customize Settings')),
  72. // component: <CustomizeSettingContents />,
  73. component: <>CustomizeSettingContents</>,
  74. },
  75. importer: {
  76. title: useCustomTitle(props, t('Import Data')),
  77. // component: <DataImportPageContents />,
  78. component: <>DataImportPageContents</>,
  79. },
  80. export: {
  81. title: useCustomTitle(props, t('Export Archive Data')),
  82. // component: <ExportArchiveDataPage />,
  83. component: <>ExportArchiveDataPage</>,
  84. },
  85. notification: {
  86. title: useCustomTitle(props, t('Notification Settings')),
  87. component: <>notification</>,
  88. },
  89. 'global-notification': {
  90. title: '',
  91. component: <>global-notification</>,
  92. },
  93. users: {
  94. title: useCustomTitle(props, t('User_Management')),
  95. // component: <UserManagement />,
  96. component: <>UserManagement</>,
  97. },
  98. 'user-groups': {
  99. title: useCustomTitle(props, t('UserGroup Management')),
  100. component: <>user-groups</>,
  101. },
  102. search: {
  103. title: useCustomTitle(props, t('Full Text Search Management')),
  104. // component: <ElasticsearchManagement />,
  105. component: <>ElasticsearchManagement</>,
  106. },
  107. };
  108. const content = adminPagesMap[name];
  109. const title = content.title;
  110. useCurrentUser(props.currentUser != null ? JSON.parse(props.currentUser) : null);
  111. // useSearchServiceConfigured(props.isSearchServiceConfigured);
  112. // useSearchServiceReachable(props.isSearchServiceReachable);
  113. useSiteUrl(props.siteUrl);
  114. // useEnvVars(props.envVars);
  115. return (
  116. <AdminLayout title={title} selectedNavOpt={name}>
  117. {content.component}
  118. </AdminLayout>
  119. );
  120. };
  121. export const getServerSideProps: GetServerSideProps = async(context: GetServerSidePropsContext) => {
  122. const req: CrowiRequest = context.req as CrowiRequest;
  123. const { crowi } = req;
  124. const {
  125. appService, searchService,
  126. } = crowi;
  127. const { user } = req;
  128. const result = await getServerSideCommonProps(context);
  129. // check for presence
  130. // see: https://github.com/vercel/next.js/issues/19271#issuecomment-730006862
  131. if (!('props' in result)) {
  132. throw new Error('invalid getSSP result');
  133. }
  134. const props: Props = result.props as Props;
  135. if (user != null) {
  136. // props.currentUser = JSON.stringify(user.toObject());
  137. props.currentUser = JSON.stringify(user);
  138. }
  139. props.siteUrl = appService.getSiteUrl();
  140. props.nodeVersion = crowi.runtimeVersions.versions.node ? crowi.runtimeVersions.versions.node.version.version : null;
  141. props.npmVersion = crowi.runtimeVersions.versions.npm ? crowi.runtimeVersions.versions.npm.version.version : null;
  142. props.yarnVersion = crowi.runtimeVersions.versions.yarn ? crowi.runtimeVersions.versions.yarn.version.version : null;
  143. props.installedPlugins = pluginUtils.listPlugins();
  144. props.envVars = await ConfigLoader.getEnvVarsForDisplay(true);
  145. props.isSearchServiceConfigured = searchService.isConfigured;
  146. props.isSearchServiceReachable = searchService.isReachable;
  147. return {
  148. props,
  149. };
  150. };
  151. export default AdminMarkdownSettingsPage;